/*
 * Copyright (c) 2024-2025 Huawei Device Co., Ltd.
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

#ifndef I_INFRARED_MANAGER
#define I_INFRARED_MANAGER

#include "parcel.h"

namespace OHOS {
namespace MMI {
struct InfraredFrequency : public Parcelable {
    int64_t max_ { 0 };
    int64_t min_ { 0 };
    bool ReadFromParcel(Parcel &parcel)
    {
        return (
            parcel.ReadInt64(max_) &&
            parcel.ReadInt64(min_)
        );
    }

    bool Marshalling(Parcel &parcel) const
    {
        if (!parcel.WriteInt64(max_)) {
            return false;
        }
        if (!parcel.WriteInt64(min_)) {
            return false;
        }
        return true;
    }

    static struct InfraredFrequency* Unmarshalling(Parcel &parcel)
    {
        auto infraredFrequency = new (std::nothrow) struct InfraredFrequency();
        if (infraredFrequency && !infraredFrequency->ReadFromParcel(parcel)) {
            delete infraredFrequency;
            infraredFrequency = nullptr;
        }

        return infraredFrequency;
    }
};
} // namespace MMI
} // namespace OHOS
#endif // I_INFRARED_MANAGER